Sensor Fusion for Kinetis MCUs (ISSDK/KSDK version)
driver_FXLS8471Q.c File Reference
+ Include dependency graph for driver_FXLS8471Q.c:

Go to the source code of this file.

Macros

#define FXLS8471Q_COUNTSPERG   8192.0
 
#define FXLS8471Q_ACCEL_FIFO_SIZE   32
 

Functions

int8_t FXLS8471Q_Init (PhysicalSensor *sensor, SensorFusionGlobals *sfg)
 
int8_t FXLS8471Q_Read (PhysicalSensor *sensor, SensorFusionGlobals *sfg)
 
int8_t FXLS8471Q_Idle (PhysicalSensor *sensor, SensorFusionGlobals *sfg)
 

Variables

const registerreadlist_t FXLS8471Q_WHO_AM_I_READ []
 
const registerreadlist_t FXLS8471Q_F_STATUS_READ []
 
registerreadlist_t FXLS8471Q_DATA_READ []
 
const registerwritelist_t FXLS8471Q_Initialization []
 
const registerwritelist_t FXLS8471Q_IDLE []
 

Detailed Description

Supports both I2C and SPI Interfaces. Supply sensor address=0x00 when when installing sensor for SPI. Supply I2C address otherwise.

Definition in file driver_FXLS8471Q.c.

Macro Definition Documentation

#define FXLS8471Q_ACCEL_FIFO_SIZE   32

Definition at line 47 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Read().

#define FXLS8471Q_COUNTSPERG   8192.0

Definition at line 46 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Init().

Function Documentation

int8_t FXLS8471Q_Idle ( PhysicalSensor sensor,
SensorFusionGlobals sfg 
)

Definition at line 234 of file driver_FXLS8471Q.c.

235 {
236  int32_t status;
237  if(sensor->isInitialized == F_USING_ACCEL) {
238  if (sensor->addr == SPI_ADDR) {
239  status = Sensor_SPI_Write(sensor->bus_driver, &(sensor->slaveParams), FXLS8471Q_IDLE );
240  } else {
241  status = Sensor_I2C_Write(sensor->bus_driver, sensor->addr, FXLS8471Q_IDLE );
242  }
243  sensor->isInitialized = 0;
244  sfg->Accel.isEnabled = false;
245  } else {
246  return SENSOR_ERROR_INIT;
247  }
248  return status;
249 }
void * bus_driver
should be of type (ARM_DRIVER_I2C* for I2C-based sensors, ARM_DRIVER_SPI* for SPI) ...
spiSlaveSpecificParams_t slaveParams
SPI specific parameters. Not used for I2C.
#define SPI_ADDR
uint16_t isInitialized
Bitfields to indicate sensor is active (use SensorBitFields from build.h)
#define F_USING_ACCEL
nominally 0x0001 if an accelerometer is to be used, 0x0000 otherwise
uint16_t addr
I2C address if applicable.
const registerwritelist_t FXLS8471Q_IDLE[]
int8_t FXLS8471Q_Init ( PhysicalSensor sensor,
SensorFusionGlobals sfg 
)

Definition at line 135 of file driver_FXLS8471Q.c.

136 {
137  GENERIC_DRIVER_GPIO *pGPIODriver = &Driver_GPIO_KSDK;
138  int32_t status;
139  uint8_t reg;
140  if (sensor->addr == SPI_ADDR) {
141  // Initialize the Slave Select Pin.
142  pGPIODriver->pin_init(&FXLS8471_SPI_CS, GPIO_DIRECTION_OUT, NULL, NULL, NULL);
143  // Initialize SPI parameters used by ISSDK SPI routines
144  sensor->slaveParams.pReadPreprocessFN = FXLS8471Q_SPI_ReadPreprocess;
145  sensor->slaveParams.pWritePreprocessFN = FXLS8471Q_SPI_WritePreprocess;
146  sensor->slaveParams.pTargetSlavePinID = &FXLS8471_SPI_CS;
147  sensor->slaveParams.spiCmdLen = FXLS8471Q_SPI_CMD_LEN;
148  sensor->slaveParams.ssActiveValue = FXLS8471Q_SS_ACTIVE_VALUE;
149  // Read the WhoAmI
150  status = Register_SPI_Read(sensor->bus_driver, &(sensor->slaveParams), FXLS8471Q_WHO_AM_I, 1, &reg);
151  } else {
152  status = Register_I2C_Read(sensor->bus_driver, sensor->addr, FXLS8471Q_WHO_AM_I, 1, &reg);
153  }
154  if (status==SENSOR_ERROR_NONE) {
155  sfg->Accel.iWhoAmI = reg;
156  if (reg!=FXLS8471Q_WHO_AM_I_WHOAMI_VALUE) return(SENSOR_ERROR_INIT);
157  } else {
158  return(status);
159  }
160 
161  // Configure and start the FXLS8471Q sensor. This does multiple register writes
162  if (sensor->addr == SPI_ADDR)
163  status = Sensor_SPI_Write(sensor->bus_driver, &(sensor->slaveParams), FXLS8471Q_Initialization );
164  else
165  status = Sensor_I2C_Write(sensor->bus_driver, sensor->addr, FXLS8471Q_Initialization );
166 
167  // Stash some needed constants in the SF data structure for this sensor
168  sfg->Accel.iCountsPerg = FXLS8471Q_COUNTSPERG;
169  sfg->Accel.fgPerCount = 1.0F / FXLS8471Q_COUNTSPERG;
170 
171  sensor->isInitialized = F_USING_ACCEL;
172  sfg->Accel.isEnabled = true;
173 
174  return (status);
175 }
#define FXLS8471Q_COUNTSPERG
const registerwritelist_t FXLS8471Q_Initialization[]
void * bus_driver
should be of type (ARM_DRIVER_I2C* for I2C-based sensors, ARM_DRIVER_SPI* for SPI) ...
spiSlaveSpecificParams_t slaveParams
SPI specific parameters. Not used for I2C.
#define SPI_ADDR
uint16_t isInitialized
Bitfields to indicate sensor is active (use SensorBitFields from build.h)
#define F_USING_ACCEL
nominally 0x0001 if an accelerometer is to be used, 0x0000 otherwise
uint16_t addr
I2C address if applicable.
int8_t FXLS8471Q_Read ( PhysicalSensor sensor,
SensorFusionGlobals sfg 
)

Definition at line 177 of file driver_FXLS8471Q.c.

178 {
179  uint8_t Data_Buffer[6 * FXLS8471Q_ACCEL_FIFO_SIZE]; // I2C read buffer
180  int8_t status=0; // I2C transaction status
181  int8_t j; // scratch
182  uint16_t sensor_fifo_count = 1;
183  int16_t sample[3];
184 
185  if(sensor->isInitialized != F_USING_ACCEL)
186  {
187  return SENSOR_ERROR_INIT;
188  }
189 
190  // read the F_STATUS register (mapped to STATUS) and extract number of measurements available (lower 6 bits)
191  if (sensor->addr == SPI_ADDR)
192  status = Sensor_SPI_Read(sensor->bus_driver, &(sensor->slaveParams), FXLS8471Q_F_STATUS_READ, Data_Buffer );
193  else
194  status = Sensor_I2C_Read(sensor->bus_driver, sensor->addr, FXLS8471Q_F_STATUS_READ, Data_Buffer );
195 
196  sensor_fifo_count = Data_Buffer[0] & 0x3F;
197  if (status==SENSOR_ERROR_NONE) {
198  // return if there are no measurements in the sensor FIFO.
199  // this will only occur when the FAST_LOOP_HZ equals or exceeds ACCEL_ODR_HZ
200  if (sensor_fifo_count == 0) return SENSOR_ERROR_READ;
201  } else {
202  return(status);
203  }
204 
205  FXLS8471Q_DATA_READ->numBytes = 6 * sensor_fifo_count;
206  if (sensor->addr == SPI_ADDR)
207  status = Sensor_SPI_Read(sensor->bus_driver, &sensor->slaveParams, FXLS8471Q_DATA_READ, &(Data_Buffer[0]) );
208  else
209  status = Sensor_I2C_Read(sensor->bus_driver, sensor->addr, FXLS8471Q_DATA_READ, &(Data_Buffer[0]) );
210 
211  if (status==SENSOR_ERROR_NONE) {
212  for (j=0; j<sensor_fifo_count; j++) {
213  sample[CHX] = (Data_Buffer[6*j ] << 8) | Data_Buffer[6*j + 1] ;
214  sample[CHY] = (Data_Buffer[6*j + 2] << 8) | Data_Buffer[6*j + 3] ;
215  sample[CHZ] = (Data_Buffer[6*j + 4] << 8) | Data_Buffer[6*j + 5] ;
216  conditionSample(sample); // truncate negative values to -32767
217  addToFifo((FifoSensor*) &(sfg->Accel), ACCEL_FIFO_SIZE, sample);
218  }
219  }
220 
221  return (status);
222 }
#define CHY
Used to access Y-channel entries in various data data structures.
Definition: sensor_fusion.h:77
void addToFifo(FifoSensor *sensor, uint16_t maxFifoSize, int16_t sample[3])
addToFifo is called from within sensor driver read functions
void * bus_driver
should be of type (ARM_DRIVER_I2C* for I2C-based sensors, ARM_DRIVER_SPI* for SPI) ...
#define ACCEL_FIFO_SIZE
FXOS8700 (accel), MMA8652, FXLS8952 all have 32 element FIFO.
The FifoSensor union allows us to use common pointers for Accel, Mag & Gyro logical sensor structures...
#define FXLS8471Q_ACCEL_FIFO_SIZE
#define CHZ
spiSlaveSpecificParams_t slaveParams
SPI specific parameters. Not used for I2C.
#define SPI_ADDR
#define CHX
Used to access X-channel entries in various data data structures.
Definition: sensor_fusion.h:76
void conditionSample(int16_t sample[3])
conditionSample ensures that we never encounter the maximum negative two&#39;s complement value for a 16-...
uint16_t isInitialized
Bitfields to indicate sensor is active (use SensorBitFields from build.h)
const registerreadlist_t FXLS8471Q_F_STATUS_READ[]
#define F_USING_ACCEL
nominally 0x0001 if an accelerometer is to be used, 0x0000 otherwise
uint16_t addr
I2C address if applicable.
registerreadlist_t FXLS8471Q_DATA_READ[]

+ Here is the call graph for this function:

Variable Documentation

registerreadlist_t FXLS8471Q_DATA_READ[]
Initial value:
=
{
{ .readFrom = FXLS8471Q_OUT_X_MSB, .numBytes = 6 }, __END_READ_DATA__
}

Definition at line 62 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Read().

const registerreadlist_t FXLS8471Q_F_STATUS_READ[]
Initial value:
=
{
{ .readFrom = FXLS8471Q_F_STATUS, .numBytes = 1 }, __END_READ_DATA__
}

Definition at line 56 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Read().

const registerwritelist_t FXLS8471Q_IDLE[]
Initial value:
=
{
{ FXLS8471Q_CTRL_REG1, 0x00, 0x01 },
__END_WRITE_DATA__
}

Definition at line 226 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Idle().

const registerwritelist_t FXLS8471Q_Initialization[]

Definition at line 68 of file driver_FXLS8471Q.c.

Referenced by FXLS8471Q_Init().

const registerreadlist_t FXLS8471Q_WHO_AM_I_READ[]
Initial value:
=
{
{ .readFrom = FXLS8471Q_WHO_AM_I, .numBytes = 1 }, __END_READ_DATA__
}

Definition at line 50 of file driver_FXLS8471Q.c.